<template>
  <div class="student">
    <h2>学生姓名：{{ name }}</h2>
    <h2>学生性别：{{ sex }}</h2>
    <h2>当前求和为：{{ number }}</h2>
    <button @click="add">点我number+1</button>
    <button @click="sendStudentName">把学生名给App</button>
    <button @click="unbind">解绑xxx事件</button>
    <button @click="des">销毁当前Student组件的实例（vc）</button>
  </div>
</template>

<script>
export default {
  name: "Student",
  data() {
    return {
      name: "张三",
      sex: "男",
      number: 0,
    };
  },
  methods: {
    sendStudentName() {
      // 触发Student组件实例身上的xxx事件
      this.$emit("xxx", this.name, 666, 888);
      // this.$emit("demo");
      // this.$emit("click");
    },
    unbind() {
      // 解绑一个自定义事件
      this.$off("xxx");
      // 解绑多个自定义事件
      // this.$off(["xxx", "demo"]);
      // 解绑所有自定义事件
      // this.$off();
    },
    add() {
      console.log("add被调用了");
      this.number++;
    },
    des() {
      // 销毁当前Student组件的实例（vc）
      this.$destroy();
      // 销毁后所有Student实例的自定义事件全都不奏效，现版本原生事件也不奏效了
    },
  },
};
</script>

<style>
.student {
  background-color: peru;
  padding: 5px;
  margin-top: 30px;
}
</style>
